博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Qt之QTableView显示富文本
阅读量:6907 次
发布时间:2019-06-27

本文共 1696 字,大约阅读时间需要 5 分钟。

简述

对于QTableView中的显示,我们前面介绍过很多种,其中包括:文本、进度条、复选框等,今天我们介绍一下关于富文本的显示。

可能绝大多数小伙伴会通过QAbstractTableModel中的data来实现,可是现实告诉我们,那是行不通的,那么我们如何去显示呢?请看正文。

效果

这里写图片描述

源码

下面我们使用QAbstractItemDelegate来进行富文本的显示,主要通过QTextDocument设置HTML代码来实现。

void CheckBoxDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const{    QStyleOptionViewItem viewOption(option);    initStyleOption(&viewOption, index);    if (option.state.testFlag(QStyle::State_HasFocus))        viewOption.state = viewOption.state ^ QStyle::State_HasFocus;    // ... 省略    // 设置显示文本为空,使用默认样式    QStyle *pStyle = viewOption.widget? viewOption.widget->style() : QApplication::style();    viewOption.text = "";    pStyle->drawControl(QStyle::CE_ItemViewItem, &viewOption, painter, viewOption.widget);    // 需要显示的HTML    QString strHTML = QString(" \                               \                               \                               \                              \                              %1%2 \                               \                               \                              ").arg("I am a ").arg("Qter");    QTextDocument doc;    doc.setHtml(strHTML);    QAbstractTextDocumentLayout::PaintContext paintContext;    QRect textRect = pStyle->subElementRect(QStyle::SE_ItemViewItemText, &viewOption);    painter->save();    // 坐标变换,将左上角设置为原点    painter->translate(textRect.topLeft());    // 设置HTML绘制区域    painter->setClipRect(textRect.translated(-textRect.topLeft()));    doc.documentLayout()->draw(painter, paintContext);    painter->restore();}

分析

首先我们需要保留原有样式,所以设置QStyleOptionViewItem的文本为空,然后调用QStyle的drawControl接口来进行绘制,然后通过QTextDocument设置HTML代码,利用QPainter来进行文本的绘制,绘制区域通过整个文本区域经过坐标变换后得到的。

你可能感兴趣的文章
关系数据库的末日是否已经来临(转载)
查看>>
第二人生 我的成长
查看>>
[转]用Hyper-v 和Failover Cluster 创建高可用性虚拟机
查看>>
硬编码写RadioGroup的时候要注意RadioButton的id重复问题
查看>>
周三 全身心的工作
查看>>
angularJS 1.0.6 tutorial 对应的github commit
查看>>
ldap的搭建
查看>>
利用percona-toolkit工具检查MySQL数据库主从一致性并修复
查看>>
Filter-全站GZIP压缩
查看>>
Windows自带的文件加密方法揭秘
查看>>
(一)ubuntu通过deb管理软件包
查看>>
单页应用开发
查看>>
【Scrapy学习】 scrapyd 文件配置
查看>>
作业-week-2
查看>>
我的友情链接
查看>>
820作业,常用命令
查看>>
TCP链接
查看>>
Java基础学习总结(4)——对象转型
查看>>
Ubuntu下安装pip的方法
查看>>
RabbitMQ学习总结(6)——消息的路由分发机制详解
查看>>